Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Components: Replace Button with ui/Button using deprecated props strategy #29990

Closed
wants to merge 6 commits into from

Conversation

sarayourfriend
Copy link
Contributor

@sarayourfriend sarayourfriend commented Mar 18, 2021

Description

Replaces the old Button's API surface with a new API surface that combines the deprecated props + the new button's props and then ultimately transforms all of them into the new button, with deprecation warnings, then renders the new button from ui/button.

This is an experimental PR as a proof of concept as an alternative to the ComponentSystemProvider strategy we're currently following.

This could be preferrable because it exposes the new API directly without forcing the old API to be a mask for the new one. You can continue to use the deprecated API with the deprecation warnings. Alternatively, you can use the new API and receive no deprecation warnings, but both are available.

Note: All the button tests will fail as they're expecting the old button implementation. We should just remove the tests and write tests for the new hook if we follow this strategy. Tests on the ui/button component should suffice.

Renamed props:

Old prop name New prop name
isPressed isActive
isBusy isLoading

I'm not sold on isLoading being better than isBusy. isBusy has a wider meaning that I think we should prefer and preserve instead of deprecating it in favor of isLoading.

isActive I think is better than isPressed though, for the same reason why isBusy is better than isLoading. isActive has a wider meaning that doesn't reference a specific type of interaction. Currently isPressed is used to indicate when the complimentary area is open, while isActive is probably a more semantic name.

Part of #29689

How has this been tested?

Storybook (npm run storybook:dev) buttons continue to work as expected.

Screenshots

Captura de Tela 2021-03-18 às 10 12 55

Captura de Tela 2021-03-18 às 10 15 44

Types of changes

Non-breaking deprecation changes.

Checklist:

  • My code is tested.
  • My code follows the WordPress code style.
  • My code follows the accessibility standards.
  • I've tested my changes with keyboard and screen readers.
  • My code has proper inline documentation.
  • I've included developer documentation if appropriate.
  • I've updated all React Native files affected by any refactorings/renamings in this PR.

@sarayourfriend sarayourfriend added [Package] Components /packages/components Storybook Storybook and its stories for components [Feature] Component System WordPress component system labels Mar 18, 2021
@sarayourfriend sarayourfriend self-assigned this Mar 18, 2021
@sarayourfriend sarayourfriend requested a review from ItsJonQ March 18, 2021 17:23
Copy link
Contributor

@youknowriad youknowriad left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is a great PR because it allows us to reason precisely about the difference in APIs and make informed decisions about whether we want to deprecate things or not.

I'll note that I think that "an API without compromises" doesn't exist, what we might think is perfect today, might not be tomorrow, for this reason, sometimes, it's fine to avoid introducing a new API even if admittedly it's better than the existing one but if it's merely a proxy or renaming of existing prop, I might ask why bother at all. This is me saying that aside "this is a better name for the prop or a better format" we might want to think about whether the tradeoff to rename or change the format of a prop is worth the deprecation or if it's it fine just to keep the old API.

That said, this is the exact kind of PR I was looking to see, we'll be able to discuss precisely the migration path. I can't review deeply now, I'll circle back later.

cc @mcsf @mtias @gziolo for feedback if you have inputs.

deprecated( 'Button icon as string', {
alternative: 'Button icon as ReactElement',
hint: 'Use the icons from @wordpress/icons',
} );
Copy link
Contributor

@youknowriad youknowriad Mar 18, 2021

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I know for instance that this is not something we can't officially deprecate yet. Blocks can use string icons and they can't rely on svg or packages in a lot of situations.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Okay! In that case we can just remove the deprecation warning, right?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

yes :)

@github-actions
Copy link

github-actions bot commented Mar 18, 2021

Size Change: -838 B (0%)

Total Size: 1.37 MB

Filename Size Change
build/a11y/index.js 1.14 kB -1 B (0%)
build/annotations/index.js 3.8 kB +15 B (0%)
build/api-fetch/index.js 3.42 kB +6 B (0%)
build/block-directory/index.js 8.63 kB +3 B (0%)
build/block-editor/index.js 127 kB +14 B (0%)
build/block-library/index.js 147 kB +15 B (0%)
build/blocks/index.js 48.3 kB -1 B (0%)
build/components/index.js 248 kB -923 B (0%)
build/compose/index.js 11.2 kB +6 B (0%)
build/core-data/index.js 16.7 kB +2 B (0%)
build/customize-widgets/index.js 3.95 kB -2 B (0%)
build/data-controls/index.js 832 B +1 B (0%)
build/data/index.js 8.88 kB -3 B (0%)
build/date/index.js 31.8 kB -1 B (0%)
build/dom/index.js 4.96 kB +1 B (0%)
build/edit-navigation/index.js 12 kB -2 B (0%)
build/edit-post/index.js 307 kB +8 B (0%)
build/edit-site/index.js 27.2 kB +1 B (0%)
build/editor/index.js 41.9 kB -7 B (0%)
build/element/index.js 4.62 kB +8 B (0%)
build/format-library/index.js 6.75 kB +1 B (0%)
build/html-entities/index.js 622 B -1 B (0%)
build/i18n/index.js 4.02 kB +7 B (0%)
build/keyboard-shortcuts/index.js 2.53 kB -1 B (0%)
build/notices/index.js 1.85 kB +6 B (0%)
build/nux/index.js 3.4 kB -1 B (0%)
build/plugins/index.js 2.89 kB -1 B (0%)
build/primitives/index.js 1.42 kB +8 B (+1%)
build/priority-queue/index.js 790 B -1 B (0%)
build/reusable-blocks/index.js 3.79 kB +10 B (0%)
build/rich-text/index.js 13.4 kB -3 B (0%)
build/server-side-render/index.js 2.58 kB +1 B (0%)
build/url/index.js 3.02 kB -1 B (0%)
build/viewport/index.js 1.86 kB -2 B (0%)
ℹ️ View Unchanged
Filename Size Change
build/autop/index.js 2.82 kB 0 B
build/blob/index.js 665 B 0 B
build/block-directory/style-rtl.css 1 kB 0 B
build/block-directory/style.css 1.01 kB 0 B
build/block-editor/style-rtl.css 12.4 kB 0 B
build/block-editor/style.css 12.4 kB 0 B
build/block-library/blocks/archives/editor-rtl.css 61 B 0 B
build/block-library/blocks/archives/editor.css 60 B 0 B
build/block-library/blocks/audio/editor-rtl.css 58 B 0 B
build/block-library/blocks/audio/editor.css 58 B 0 B
build/block-library/blocks/audio/style-rtl.css 112 B 0 B
build/block-library/blocks/audio/style.css 112 B 0 B
build/block-library/blocks/block/editor-rtl.css 161 B 0 B
build/block-library/blocks/block/editor.css 161 B 0 B
build/block-library/blocks/button/editor-rtl.css 475 B 0 B
build/block-library/blocks/button/editor.css 474 B 0 B
build/block-library/blocks/button/style-rtl.css 479 B 0 B
build/block-library/blocks/button/style.css 479 B 0 B
build/block-library/blocks/buttons/editor-rtl.css 315 B 0 B
build/block-library/blocks/buttons/editor.css 315 B 0 B
build/block-library/blocks/buttons/style-rtl.css 364 B 0 B
build/block-library/blocks/buttons/style.css 363 B 0 B
build/block-library/blocks/calendar/style-rtl.css 208 B 0 B
build/block-library/blocks/calendar/style.css 208 B 0 B
build/block-library/blocks/categories/editor-rtl.css 84 B 0 B
build/block-library/blocks/categories/editor.css 83 B 0 B
build/block-library/blocks/categories/style-rtl.css 79 B 0 B
build/block-library/blocks/categories/style.css 79 B 0 B
build/block-library/blocks/code/style-rtl.css 90 B 0 B
build/block-library/blocks/code/style.css 90 B 0 B
build/block-library/blocks/columns/editor-rtl.css 190 B 0 B
build/block-library/blocks/columns/editor.css 190 B 0 B
build/block-library/blocks/columns/style-rtl.css 421 B 0 B
build/block-library/blocks/columns/style.css 421 B 0 B
build/block-library/blocks/cover/editor-rtl.css 605 B 0 B
build/block-library/blocks/cover/editor.css 605 B 0 B
build/block-library/blocks/cover/style-rtl.css 1.24 kB 0 B
build/block-library/blocks/cover/style.css 1.24 kB 0 B
build/block-library/blocks/embed/editor-rtl.css 486 B 0 B
build/block-library/blocks/embed/editor.css 486 B 0 B
build/block-library/blocks/embed/style-rtl.css 401 B 0 B
build/block-library/blocks/embed/style.css 400 B 0 B
build/block-library/blocks/file/editor-rtl.css 199 B 0 B
build/block-library/blocks/file/editor.css 198 B 0 B
build/block-library/blocks/file/style-rtl.css 248 B 0 B
build/block-library/blocks/file/style.css 248 B 0 B
build/block-library/blocks/freeform/editor-rtl.css 2.46 kB 0 B
build/block-library/blocks/freeform/editor.css 2.46 kB 0 B
build/block-library/blocks/gallery/editor-rtl.css 704 B 0 B
build/block-library/blocks/gallery/editor.css 705 B 0 B
build/block-library/blocks/gallery/style-rtl.css 1.11 kB 0 B
build/block-library/blocks/gallery/style.css 1.1 kB 0 B
build/block-library/blocks/group/editor-rtl.css 160 B 0 B
build/block-library/blocks/group/editor.css 160 B 0 B
build/block-library/blocks/group/style-rtl.css 57 B 0 B
build/block-library/blocks/group/style.css 57 B 0 B
build/block-library/blocks/heading/editor-rtl.css 129 B 0 B
build/block-library/blocks/heading/editor.css 129 B 0 B
build/block-library/blocks/heading/style-rtl.css 76 B 0 B
build/block-library/blocks/heading/style.css 76 B 0 B
build/block-library/blocks/html/editor-rtl.css 281 B 0 B
build/block-library/blocks/html/editor.css 281 B 0 B
build/block-library/blocks/image/editor-rtl.css 717 B 0 B
build/block-library/blocks/image/editor.css 716 B 0 B
build/block-library/blocks/image/style-rtl.css 476 B 0 B
build/block-library/blocks/image/style.css 478 B 0 B
build/block-library/blocks/latest-comments/editor-rtl.css 159 B 0 B
build/block-library/blocks/latest-comments/editor.css 158 B 0 B
build/block-library/blocks/latest-comments/style-rtl.css 269 B 0 B
build/block-library/blocks/latest-comments/style.css 269 B 0 B
build/block-library/blocks/latest-posts/editor-rtl.css 137 B 0 B
build/block-library/blocks/latest-posts/editor.css 137 B 0 B
build/block-library/blocks/latest-posts/style-rtl.css 523 B 0 B
build/block-library/blocks/latest-posts/style.css 522 B 0 B
build/block-library/blocks/list/editor-rtl.css 65 B 0 B
build/block-library/blocks/list/editor.css 65 B 0 B
build/block-library/blocks/list/style-rtl.css 63 B 0 B
build/block-library/blocks/list/style.css 63 B 0 B
build/block-library/blocks/media-text/editor-rtl.css 191 B 0 B
build/block-library/blocks/media-text/editor.css 191 B 0 B
build/block-library/blocks/media-text/style-rtl.css 535 B 0 B
build/block-library/blocks/media-text/style.css 532 B 0 B
build/block-library/blocks/more/editor-rtl.css 434 B 0 B
build/block-library/blocks/more/editor.css 434 B 0 B
build/block-library/blocks/navigation-link/editor-rtl.css 626 B 0 B
build/block-library/blocks/navigation-link/editor.css 627 B 0 B
build/block-library/blocks/navigation-link/style-rtl.css 680 B 0 B
build/block-library/blocks/navigation-link/style.css 678 B 0 B
build/block-library/blocks/navigation/editor-rtl.css 1.11 kB 0 B
build/block-library/blocks/navigation/editor.css 1.11 kB 0 B
build/block-library/blocks/navigation/style-rtl.css 204 B 0 B
build/block-library/blocks/navigation/style.css 205 B 0 B
build/block-library/blocks/nextpage/editor-rtl.css 395 B 0 B
build/block-library/blocks/nextpage/editor.css 395 B 0 B
build/block-library/blocks/page-list/editor-rtl.css 170 B 0 B
build/block-library/blocks/page-list/editor.css 170 B 0 B
build/block-library/blocks/page-list/style-rtl.css 537 B 0 B
build/block-library/blocks/page-list/style.css 536 B 0 B
build/block-library/blocks/paragraph/editor-rtl.css 157 B 0 B
build/block-library/blocks/paragraph/editor.css 157 B 0 B
build/block-library/blocks/paragraph/style-rtl.css 247 B 0 B
build/block-library/blocks/paragraph/style.css 248 B 0 B
build/block-library/blocks/post-author/editor-rtl.css 209 B 0 B
build/block-library/blocks/post-author/editor.css 209 B 0 B
build/block-library/blocks/post-author/style-rtl.css 183 B 0 B
build/block-library/blocks/post-author/style.css 184 B 0 B
build/block-library/blocks/post-comments-form/style-rtl.css 250 B 0 B
build/block-library/blocks/post-comments-form/style.css 250 B 0 B
build/block-library/blocks/post-content/editor-rtl.css 139 B 0 B
build/block-library/blocks/post-content/editor.css 139 B 0 B
build/block-library/blocks/post-excerpt/editor-rtl.css 73 B 0 B
build/block-library/blocks/post-excerpt/editor.css 73 B 0 B
build/block-library/blocks/post-featured-image/editor-rtl.css 338 B 0 B
build/block-library/blocks/post-featured-image/editor.css 338 B 0 B
build/block-library/blocks/post-featured-image/style-rtl.css 100 B 0 B
build/block-library/blocks/post-featured-image/style.css 100 B 0 B
build/block-library/blocks/preformatted/style-rtl.css 63 B 0 B
build/block-library/blocks/preformatted/style.css 63 B 0 B
build/block-library/blocks/pullquote/editor-rtl.css 183 B 0 B
build/block-library/blocks/pullquote/editor.css 183 B 0 B
build/block-library/blocks/pullquote/style-rtl.css 318 B 0 B
build/block-library/blocks/pullquote/style.css 318 B 0 B
build/block-library/blocks/query-loop/editor-rtl.css 90 B 0 B
build/block-library/blocks/query-loop/editor.css 89 B 0 B
build/block-library/blocks/query-loop/style-rtl.css 315 B 0 B
build/block-library/blocks/query-loop/style.css 317 B 0 B
build/block-library/blocks/query-pagination-numbers/editor-rtl.css 122 B 0 B
build/block-library/blocks/query-pagination-numbers/editor.css 121 B 0 B
build/block-library/blocks/query-pagination/editor-rtl.css 270 B 0 B
build/block-library/blocks/query-pagination/editor.css 262 B 0 B
build/block-library/blocks/query-pagination/style-rtl.css 168 B 0 B
build/block-library/blocks/query-pagination/style.css 168 B 0 B
build/block-library/blocks/query-title/editor-rtl.css 86 B 0 B
build/block-library/blocks/query-title/editor.css 86 B 0 B
build/block-library/blocks/query/editor-rtl.css 820 B 0 B
build/block-library/blocks/query/editor.css 819 B 0 B
build/block-library/blocks/quote/editor-rtl.css 61 B 0 B
build/block-library/blocks/quote/editor.css 61 B 0 B
build/block-library/blocks/quote/style-rtl.css 169 B 0 B
build/block-library/blocks/quote/style.css 169 B 0 B
build/block-library/blocks/rss/editor-rtl.css 201 B 0 B
build/block-library/blocks/rss/editor.css 202 B 0 B
build/block-library/blocks/rss/style-rtl.css 290 B 0 B
build/block-library/blocks/rss/style.css 290 B 0 B
build/block-library/blocks/search/editor-rtl.css 165 B 0 B
build/block-library/blocks/search/editor.css 165 B 0 B
build/block-library/blocks/search/style-rtl.css 342 B 0 B
build/block-library/blocks/search/style.css 344 B 0 B
build/block-library/blocks/separator/editor-rtl.css 99 B 0 B
build/block-library/blocks/separator/editor.css 99 B 0 B
build/block-library/blocks/separator/style-rtl.css 236 B 0 B
build/block-library/blocks/separator/style.css 236 B 0 B
build/block-library/blocks/shortcode/editor-rtl.css 512 B 0 B
build/block-library/blocks/shortcode/editor.css 512 B 0 B
build/block-library/blocks/site-logo/editor-rtl.css 201 B 0 B
build/block-library/blocks/site-logo/editor.css 201 B 0 B
build/block-library/blocks/site-logo/style-rtl.css 115 B 0 B
build/block-library/blocks/site-logo/style.css 115 B 0 B
build/block-library/blocks/social-link/editor-rtl.css 164 B 0 B
build/block-library/blocks/social-link/editor.css 165 B 0 B
build/block-library/blocks/social-links/editor-rtl.css 776 B 0 B
build/block-library/blocks/social-links/editor.css 776 B 0 B
build/block-library/blocks/social-links/style-rtl.css 1.32 kB 0 B
build/block-library/blocks/social-links/style.css 1.33 kB 0 B
build/block-library/blocks/spacer/editor-rtl.css 317 B 0 B
build/block-library/blocks/spacer/editor.css 317 B 0 B
build/block-library/blocks/spacer/style-rtl.css 48 B 0 B
build/block-library/blocks/spacer/style.css 48 B 0 B
build/block-library/blocks/table/editor-rtl.css 478 B 0 B
build/block-library/blocks/table/editor.css 478 B 0 B
build/block-library/blocks/table/style-rtl.css 402 B 0 B
build/block-library/blocks/table/style.css 402 B 0 B
build/block-library/blocks/tag-cloud/editor-rtl.css 118 B 0 B
build/block-library/blocks/tag-cloud/editor.css 118 B 0 B
build/block-library/blocks/tag-cloud/style-rtl.css 94 B 0 B
build/block-library/blocks/tag-cloud/style.css 94 B 0 B
build/block-library/blocks/template-part/editor-rtl.css 552 B 0 B
build/block-library/blocks/template-part/editor.css 551 B 0 B
build/block-library/blocks/term-description/editor-rtl.css 90 B 0 B
build/block-library/blocks/term-description/editor.css 90 B 0 B
build/block-library/blocks/text-columns/editor-rtl.css 95 B 0 B
build/block-library/blocks/text-columns/editor.css 95 B 0 B
build/block-library/blocks/text-columns/style-rtl.css 166 B 0 B
build/block-library/blocks/text-columns/style.css 166 B 0 B
build/block-library/blocks/verse/editor-rtl.css 50 B 0 B
build/block-library/blocks/verse/editor.css 50 B 0 B
build/block-library/blocks/verse/style-rtl.css 87 B 0 B
build/block-library/blocks/verse/style.css 87 B 0 B
build/block-library/blocks/video/editor-rtl.css 504 B 0 B
build/block-library/blocks/video/editor.css 503 B 0 B
build/block-library/blocks/video/style-rtl.css 187 B 0 B
build/block-library/blocks/video/style.css 187 B 0 B
build/block-library/common-rtl.css 1.1 kB 0 B
build/block-library/common.css 1.1 kB 0 B
build/block-library/editor-rtl.css 9.48 kB 0 B
build/block-library/editor.css 9.48 kB 0 B
build/block-library/style-rtl.css 8.88 kB 0 B
build/block-library/style.css 8.88 kB 0 B
build/block-library/theme-rtl.css 700 B 0 B
build/block-library/theme.css 701 B 0 B
build/block-serialization-default-parser/index.js 1.88 kB 0 B
build/block-serialization-spec-parser/index.js 3.06 kB 0 B
build/components/style-rtl.css 16.2 kB 0 B
build/components/style.css 16.2 kB 0 B
build/customize-widgets/style-rtl.css 168 B 0 B
build/customize-widgets/style.css 168 B 0 B
build/deprecated/index.js 768 B 0 B
build/dom-ready/index.js 576 B 0 B
build/edit-navigation/style-rtl.css 1.31 kB 0 B
build/edit-navigation/style.css 1.31 kB 0 B
build/edit-post/style-rtl.css 7.12 kB 0 B
build/edit-post/style.css 7.11 kB 0 B
build/edit-site/style-rtl.css 4.55 kB 0 B
build/edit-site/style.css 4.55 kB 0 B
build/edit-widgets/index.js 20.2 kB 0 B
build/edit-widgets/style-rtl.css 3.2 kB 0 B
build/edit-widgets/style.css 3.2 kB 0 B
build/editor/editor-styles-rtl.css 347 B 0 B
build/editor/editor-styles.css 347 B 0 B
build/editor/style-rtl.css 3.9 kB 0 B
build/editor/style.css 3.9 kB 0 B
build/escape-html/index.js 735 B 0 B
build/format-library/style-rtl.css 637 B 0 B
build/format-library/style.css 639 B 0 B
build/hooks/index.js 2.28 kB 0 B
build/is-shallow-equal/index.js 698 B 0 B
build/keycodes/index.js 1.95 kB 0 B
build/list-reusable-blocks/index.js 3.14 kB 0 B
build/list-reusable-blocks/style-rtl.css 629 B 0 B
build/list-reusable-blocks/style.css 628 B 0 B
build/media-utils/index.js 5.34 kB 0 B
build/nux/style-rtl.css 731 B 0 B
build/nux/style.css 727 B 0 B
build/react-i18n/index.js 1.46 kB 0 B
build/redux-routine/index.js 2.84 kB 0 B
build/reusable-blocks/style-rtl.css 225 B 0 B
build/reusable-blocks/style.css 225 B 0 B
build/shortcode/index.js 1.7 kB 0 B
build/token-list/index.js 1.27 kB 0 B
build/warning/index.js 1.14 kB 0 B
build/wordcount/index.js 1.22 kB 0 B

compressed-size-action

@ItsJonQ
Copy link

ItsJonQ commented Mar 18, 2021

@sarayourfriend I think this is a great approach! The "breakdown" of the individual deprecated props provides a replicable strategy for handling remapping/deprecation/(removal?) of props :).

I think Button is honestly the most challenging component due to how common it is within the UI (both from core and 3rd party).


Running Gutenberg locally, we can see the UI breaking in many areas 🙈 .

Screen Shot 2021-03-18 at 2 01 10 PM

Screen Shot 2021-03-18 at 2 03 09 PM

It's mostly style based. However, I think this reveals a lot of awkward / sub-optimal uses of Button.


A downside of this strategy is that we can't incrementally scope and roll-out the new implementation - via the protection of the Context System.


I think it's worth noting that there's a difference between rendering a UI with button HTML, and using the actual Button component. In the case of the Inserter tiles (screenshot above), I don't think they should be using the Button component as a base.

@sarayourfriend
Copy link
Contributor Author

Thanks for the screenshot @ItsJonQ. That really illustrates one of the significant difficulties of this migration process. Like you said, the approach taken in this PR doesn't allow for piecemeal, area-by-area adaption. The new component must work for all instances. I think that's a fine expectation if we take this approach, but obviously more work needs to be done on ui/button before it's actually feasible.

@sarayourfriend
Copy link
Contributor Author

I upgraded G2 and it fixes some of the problems but not all. Upgrading G2 gets us the new low specificity.

@gziolo
Copy link
Member

gziolo commented Mar 19, 2021

I'll note that I think that "an API without compromises" doesn't exist, what we might think is perfect today, might not be tomorrow, for this reason, sometimes, it's fine to avoid introducing a new API even if admittedly it's better than the existing one but if it's merely a proxy or renaming of existing prop, I might ask why bother at all. This is me saying that aside "this is a better name for the prop or a better format" we might want to think about whether the tradeoff to rename or change the format of a prop is worth the deprecation or if it's it fine just to keep the old API.

I echo what @youknowriad mentioned. I see that public APIs between the old and new version of the button differs a lot. I would personally look at this from a plugin developer perspective that might suddenly see a big number of warnings coming from components they use in the project. There isn't any immediate benefit for them to start using the latest API because the button will work more or less the same. It's important to be aware of that side of the components adoption and ensure that it doesn't become too troublesome and folks will lose confidence in using WordPress components.

@sarayourfriend
Copy link
Contributor Author

A couple questions for @ItsJonQ regarding this PR.

I think this PR exposes something about G2's Button that was not talked about yet. Basically, it is too different from the existing Button. Aside from API improvements, are there aspects of the G2 Button that are "must haves" that the current Button does not implement?

My thought behind asking this question is: can we actually just use the existing button, improve it in some ways (including by refining the API to use a variant prop instead of the various is* props)? Button in particular seems like a bit of a quagmire in that it is used all over the place. I don't think we'll be able to achieve a reasonable integration strategy that includes Button because of this. A more straightforward option would be to just improve the existing Button, potentially rolling the existing button into the G2 style system so that it can be targeted using Component Interpolation in styled components to make way for ButtonGroup's automagic handling of rounded corners and such (one thing the new Button does well that we should backport into the existing one if we just keep the existing one).

Are there also other components we can do this with?

I'm going to open two new PRs that are inspired by this one. One for Text and one for Flex. I think these components in general can actually use this current strategy and get to a mergable place soon.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
[Feature] Component System WordPress component system [Package] Components /packages/components Storybook Storybook and its stories for components
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants